- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 393
          Add gix_path::relative_path::RelativePath
          #1921
        
          New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for getting this started.
Besides my notes, one key aspect of it is that there is a &RepositoryPath that only exists as reference, similar to PathBuf/&Path. An example for this is gix-ref::FileName|&FileNameRef, it needs some unsafe to do the conversion.
Finally, there must be an std::str::from_utf8_unchecked() equivalent for APIs that only have a single component, for example, or do their own validation naturally as part of the parsing.
This leads me to an interesting observation: gix_object::Tree::entries actually only has a RepositoryPathComponent, which might be a type we want explicitly just to say it's definitely not having slashes in there.
And with all this as a start, I think it will come together naturally.
        
          
                gix-object/src/tree/mod.rs
              
                Outdated
          
        
      | } | ||
| } | ||
|  | ||
| impl std::ops::Deref for RepositoryPathPuf { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The idea would be to avoid having easy conversions to BString and treat it as distinct type with its own PathBuf-like API.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Absolutely! This was just a shortcut to get this first addition to compile with the least amount of changes possible (I should have been more clear about the context and the status of this initial commit).
A more general question: is the idea to have both the new types backed by inner: BString (and inner: &BStr) or rather by inner: Vec<u8> (and inner: &[u8])? If the latter, we would need to implement all the necessary functions that are currently provided by BString (and &BStr) ourselves, or am I missing something?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The path of least resistance (and the preferred one) should be to let it be backed by BString|&BStr. Maybe this will also be a great preparation for the time when std::…::ByteString can be used, when only the backing needs to be adjusted as most code is using RepositoryPathComponent|RepositoryPathBuf and friends.
        
          
                gix-object/src/tree/mod.rs
              
                Outdated
          
        
      | } | ||
| } | ||
|  | ||
| impl From<BString> for RepositoryPathPuf { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There should be no API that converts to this type without checking the input - paths now have to be relative.
        
          
                gix-object/src/tree/mod.rs
              
                Outdated
          
        
      | } | ||
|  | ||
| /// TODO | ||
| /// Keep in mind that the path separator always is `/`, independent of the platform. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And on top of that, it's a relative path with only Normal path components. Also it's always represented as bunch of bytes.
| I removed  
 Is this what you had in mind? Next, I want to convert the  | 
| Apologies for the late response, and thanks for pushing this forward. 
 Yes, that seems like the way to go. I didn't check the code and maybe the documentation of  
 That seems like something one could expect for a bundle-of-bytes path type. 
 Now that I see this I wonder if it should be a bundle of bytes, and as such can deref to bytes so it can be used similarly as Git would do in C. 
 That sounds good! I didn't look at the code yet, but would do so after your next session. If that feels a little unsafe, please let me know and I will get to it earlier. | 
2b8f377    to
    574d003      
    Compare
  
    | Thanks for the feedback! I rebased the PR and made a few more changes. I mainly replaced the  
 | 
| Thanks so much for continuing this adventure with me :)! While starting to work on looking at the PR more thoroughly, I realised that there is another thing to consider: Even though users of the API should be able to leverage the type-system,  Once again, I kept it quick, letting your questions drive me. 
 It's for tests and and it's related to  
 I think that's also related to  
 I think  
 I always thought that  
 I think it's OK to keep it as  On another note, I'd turn  And here it comes: Since  In a way,  So (at least) one question remains: where would the user get these paths?  So in short, I think what should be done is to leave  Does that make any sense? | 
| 
 Just to make sure I understand correctly: are you suggesting we change  gitoxide/gix-index/src/entry/mod.rs Lines 79 to 87 in 71c0092 
 Also, I discovered there is  Update: I’ve updated the first link that now correctly points to  | 
| 
 I don't know exactly which  
 That seems like the way to go to validate components in a  | 
| 
 I’m sorry, I included an incorrect link in my response, this is the correct one: gitoxide/gix-index/src/entry/mod.rs Lines 79 to 87 in 71c0092 
 | 
| Yes, that's where I would have expected methods just like you indicate. Just that these days I try to stick more to  | 
| Another, and probably more interesting usage of  This one is interesting as it's not relative to the worktree, but relative to the repository directory  | 
71c0092    to
    4a016f1      
    Compare
  
    | I added  
 I have not yet removed the older commits some of which might be obsolete by now. I want to to that once this PR is closer to its final version. | 
| 
 I think it's better to call it  
 I think so, too. 
 I think that's the way. In the non-plumbing crate,  
 From something Owned to a reference won't work. But one can go from  
 Yes, that duplication of validation can then be removed. 
 It returns  I hope that helps. | 
| I hope we’re getting closer. 😄 
 | 
| 
 It sure looks like it 🔥🙌. 
 There Git would have to decide - does it error if the path (as configured) is absolute? 
 This is the way 👋. 
 Actually, that's a great catch and probably a Bug. I really am trying to make progress in #1825 and will push a fix there. Right now,  | 
| 
 Awesome! I’ll rebase once the fix is available. | 
| 
 Git errors, so I’ll turn this into an error: Relevant context: | 
| 
 Now, I’m waiting for #1825 to be merged. In the meantime, I’ll keep this PR up to date and try to get CI to pass. | 
| 
 That's great! Probably this automatically catches errors that it didn't care about previously. 
 My thinking here is to always use  
 That sounds good! The PR is now merged as well. | 
3ec40ae    to
    3bb9215      
    Compare
  
    | @Byron It seems that at this point it would be best to completely remove the parts that are related to  | 
f02d1bf    to
    3994c09      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's a great point! (and apologies for the late response)
I took the liberty of doing just that, while undoing all the changes that came with it in tree::Entry. Maybe this makes CI pass as well.
Let me also share the latest insights gained from #1935 which is in short: Ref types will prefer to refer to their underlying buffer verbatim, and are able to represent invalid data as well. The non-Ref (owned) sibling type will contain only validated and strongly typed data.
This means that the Entry::filename field should one day be a PathComponent of sorts, but EntryRef::filename remains a BStr.
| 
 Thanks a lot, much appreciated! 
 Does that mean that, in this PR,  | 
| 
 I don't think so - after all, no portion of the code ever wanted to store a type-safe version of  So the actual question is if anything would be missing here. And maybe it's not much at all if anything. | 
| 
 This PR is mostly done from my side. There’s some duplication in the tests and in the  | 
| Sounds good! | 
7dec60c    to
    00a50ed      
    Compare
  
    gix_path::relative_path::RelativePath
      | I’m done, the PR is ready for review! | 
It's a utility to assure functions get the right input, i.e. a type-safe version of what previously was `&BStr`
4b62bb0    to
    23e2498      
    Compare
  
    That way there now is a type to capture requirements. Co-authored-by: Sebastian Thiel <[email protected]>
0286f33    to
    a757803      
    Compare
  
    Its type captures the requirements better. Co-authored-by: Sebastian Thiel <[email protected]>
… not a `Path`. Previously it was possible for strings or BString/BStr to contain non-normal components, now there is much more validation.
a757803    to
    d139fa4      
    Compare
  
    
This is a PoC that adds
RepositoryPathBufingix_object::tree, for initial use ingix_object::tree::Entry. It is intended to make sure I start making the right changes in the right places.This PR adds
RepositoryPathBufand uses it forgix_object::tree::Entry::filename. I adapted other places in the code until I gotjust checkpassing.